<template>
  <!-- svg: 图标外层容器节点，内部需要与 use 标签结合使用 -->
  <svg :style="{ width: width, height: height }">
    <!--
      xlink:href 属性用来执行使用哪个图标，自SVG 2规范起，推荐直接使用href属性代替xlink:href，
      虽然大多数浏览器仍然支持xlink:href出于向后兼容的原因。
      属性值务必以 #icon-图标名字 方式使用，如：xlink:href="#icon-plane"。
      use 标签的 fill 属性可以设置图标颜色。
    -->
    <use :href="prefix + name" :fill="color"></use>
  </svg>
</template>

<script setup lang="ts">
// 接收父组件传递过来的参数
defineProps({
  // xlink:href 属性值的前缀
  prefix: {
    type: String,
    default: '#icon-',
  },
  // 提供使用的图标的名字
  name: {
    type: String,
  },
  // 接收父组件传递的图标的颜色
  color: {
    type: String,
    default: 'pink',
  },
  // 接收父组件传递过来的图标的宽度
  width: {
    type: String,
    default: '16px',
  },
  // 接收父组件传递过来的图标的高度
  height: {
    type: String,
    default: '16px',
  },
})
</script>

<style scoped></style>
